﻿Imports ISNet.WebUI.WebGrid
Imports System
Imports System.Data
Imports System.Configuration
Imports System.Collections
Imports System.Web
Imports System.Web.Security
Imports System.Web.UI
Imports System.Web.UI.WebControls
Imports System.Web.UI.WebControls.WebParts
Imports System.Web.UI.HtmlControls
Imports System.Collections.Generic
Imports System.Linq
Imports ISNet.WebUI.WebTreeView
Imports log4net

Partial Class mtFundedProgramAsset
    Inherits System.Web.UI.Page

    Private Shared logger As ILog = LogManager.GetLogger("mtFundedProgramAsset")

    Protected Sub Page_Load(sender As Object, e As EventArgs) Handles Me.Load
        'Session("PlanYear") = "2557"
        ScreenName.Text = "ระบบจัดทำงบประมาณ  >>  ตั้งค่าระบบ >> Funded Program Asset"
        'Session("users") = "bb0011"
        If Session("users") Is Nothing Then
            Response.Redirect("LoginForm.aspx")
        End If
        
        If IsPostBack = False Then
            PlanYearsTxt.Text = Session("PlanYear")
            Session("PlanYearTxt") = PlanYearsTxt.Text
            Session("SearchTxt") = ""
            Session("SearchTxt") = " and PlanYear = " & PlanYearsTxt.Text
        End If

    End Sub

    Protected Sub WebGrid1_InitializeDataSource(ByVal sender As Object, ByVal e As ISNet.WebUI.WebGrid.DataSourceEventArgs) Handles WebGrid1.InitializeDataSource
        Dim adapter As New MasterDataSetTableAdapters.FundedProgramAssetsTableAdapter
        Dim dtTable As New MasterDataSet.FundedProgramAssetsDataTable

        Dim sql As String = "select * from FundedProgramAssets "
        sql += " WHERE 1 = 1 "

        If FundedCodeTxt.Text = " " And FundedCodeTxt.Text = "" Then
            sql += " and PlanYear = " & PlanYearsTxt.Text
        Else
            sql += Session("SearchTxt")
        End If

        sql += " ORDER BY FundedProgram"

        adapter.SearchFundedProgAsset(dtTable, sql)
        'Response.Write(sql)

        Session("count_data") = dtTable.Rows.Count

        dtTable.Columns("FundedProgram").AllowDBNull = True
        dtTable.Columns("Version").AllowDBNull = True
        dtTable.Columns("PlanYear").AllowDBNull = True
        dtTable.Columns("BaseYear").AllowDBNull = True
        dtTable.Columns("BudgetDetail_Id").AllowDBNull = True

        e.DataSource = dtTable

    End Sub

    Protected Sub WebGrid1_InitializeRow(ByVal sender As Object, ByVal e As ISNet.WebUI.WebGrid.RowEventArgs)
        ' don't edit column
        e.Row.Cells(2).ForceNoEdit = True
        e.Row.Cells(3).ForceNoEdit = True
        e.Row.Cells(5).ForceNoEdit = True
    End Sub

    Protected Sub WebGrid1_AddRow(ByVal sender As Object, ByVal e As ISNet.WebUI.WebGrid.RowEventArgs)
        Dim adapter As New MasterDataSetTableAdapters.FundedProgramAssetsTableAdapter
        Dim check = adapter.CheckExistFundedProAsset(Val(e.Row.Cells(2).Value), Val(e.Row.Cells(3).Value), e.Row.Cells(4).Value, e.Row.Cells(1).Value)

        If check <> 0 Then
            WebGrid1.ClearCachedDataSource()
            WebGrid1.ClientAction.Refresh()
            Throw New ArgumentException("ข้อมูลซ้ำกับที่มีอยู่ กรุณาตรวจสอบ")
        Else
            Dim id As Decimal
            id = adapter.InsertFundedProAsset(Val(e.Row.Cells(2).Value), Val(e.Row.Cells(3).Value), e.Row.Cells(4).Value, e.Row.Cells(1).Value, Date.Now, Session("users"))
            Dim dr As DataRow = e.Row.DataRow
            dr("id") = id

            logger.Info("User " & Session("users") & " insert funded program " & e.Row.Cells(1).Value)
        End If

    End Sub

    Protected Sub WebGrid1_UpdateRow(ByVal sender As Object, ByVal e As ISNet.WebUI.WebGrid.RowEventArgs)
        Dim id As String
        id = e.Row.KeyValue
        Dim adapter As New MasterDataSetTableAdapters.FundedProgramAssetsTableAdapter
        Dim check = adapter.CheckExistUpdate(Val(e.Row.Cells(2).Value), Val(e.Row.Cells(3).Value), e.Row.Cells(4).Value, e.Row.Cells(1).Value, id)

        If check = 1 Then
            WebGrid1.ClearCachedDataSource()
            WebGrid1.ClientAction.Refresh()
            Throw New ArgumentException("ข้อมูลซ้ำกับที่มีอยู่ กรุณาตรวจสอบ")
        Else
            adapter.UpdateFundedProAsset(Val(e.Row.Cells(2).Value), Val(e.Row.Cells(3).Value), e.Row.Cells(4).Value, e.Row.Cells(1).Value, Date.Now, Session("users"), id)
            logger.Info("User " & Session("users") & " update funded program " & e.Row.Cells(1).Value)
        End If
    End Sub

    Protected Sub WebGrid1_InitializePostBack(ByVal sender As Object, ByVal e As ISNet.WebUI.WebGrid.PostbackEventArgs)
        If e.Action = PostBackAction.Custom Then
            Dim type As String = TryCast(Request("type"), String)
            Dim Deletet As String = TryCast(Request("id"), String)
            Dim adapter As New MasterDataSetTableAdapters.FundedProgramAssetsTableAdapter

            If type = "1" Then
                ' MsgBox(Deletet)
                adapter.DeleteFundedProAsset(Deletet)
                logger.Info("User " & Session("users") & " delete funded program " & Deletet)

            ElseIf type = "2" Then
                For Each keyValue As String In WebGrid1.RootTable.GetCheckedRows()
                    adapter.DeleteFundedProAsset(keyValue)
                    logger.Info("User " & Session("users") & " delete funded program" & keyValue)
                Next keyValue
            End If
            WebGrid1.ClientAction.Refresh()
        End If
    End Sub

    Protected Sub SearhBtn_Click(sender As Object, e As ImageClickEventArgs) Handles SearhBtn.Click
        Session("SearchTxt") = ""
        If (PlanYearsTxt.Text <> " " And PlanYearsTxt.Text <> "") Then
            Session("SearchTxt") += " and PlanYear = " & PlanYearsTxt.Text
        End If
        If (BaseYearTxt.Text <> " " And BaseYearTxt.Text <> "") Then
            Session("SearchTxt") += " and BaseYear = " & BaseYearTxt.Text
        End If
        If (VersionTxt.Text <> " " And VersionTxt.Text <> "") Then
            Session("SearchTxt") += " and Version like  '%" & VersionTxt.Text & "%'"
        End If
        If (FundedCodeTxt.Text <> " " And FundedCodeTxt.Text <> "") Then
            Session("SearchTxt") += " and FundedProgram like '%" & FundedCodeTxt.Text & "%'"
        End If

        WebGrid1.ClearCachedDataSource()
        WebGrid1.RebindDataSource()
        t_countdata.Visible = True
        If Val(Session("count_data")) > 0 Then
            L_CountData.Text = FormatNumber(Val(Session("count_data")), 0) & " รายการ"
        Else
            L_CountData.Text = "ไม่พบข้อมูลที่ค้นหา"
        End If
    End Sub

    Protected Sub SaveBtn_Click(sender As Object, e As ImageClickEventArgs) Handles SaveBtn.Click
        WebGrid1.ClearCachedDataSource()
        WebGrid1.RebindDataSource()
    End Sub

    Protected Sub VersionCombo_InitializeDataSource(sender As Object, e As ISNet.WebUI.WebCombo.DataSourceEventArgs) Handles VersionCombo.InitializeDataSource
        Dim adap As New MasterDataSet2TableAdapters.BudgetVersionsTableAdapter
        Dim dt As New MasterDataSet2.BudgetVersionsDataTable
        dt = adap.GetData
        e.DataSource = dt
    End Sub
End Class
